home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Chip: Internet
/
Chip Internet.iso
/
viewer
/
sox7dos
/
reverse.c
< prev
next >
Wrap
Text File
|
1993-02-11
|
3KB
|
138 lines
/*
* June 1, 1992
* Copyright 1992 Guido van Rossum And Sundry Contributors
* This source code is freely redistributable and may be used for
* any purpose. This copyright notice must be maintained.
* Guido van Rossum And Sundry Contributors are not responsible for
* the consequences of using this software.
*/
/*
* "reverse" effect, uses a temporary file created by tmpfile().
*/
#include "st.h"
#include <math.h>
IMPORT FILE *tmpfile();
#ifndef SEEK_SET
#define SEEK_SET 0
#endif
#ifndef SEEK_CUR
#define SEEK_CUR 1
#endif
#ifndef SEEK_END
#define SEEK_END 2
#endif
/* Private data */
typedef struct reversestuff {
FILE *fp;
long pos;
int phase;
} *reverse_t;
#define WRITING 0
#define READING 1
/*
* Process options: none in our case.
*/
reverse_getopts(effp, n, argv)
eff_t effp;
int n;
char **argv;
{
if (n)
fail("Reverse effect takes no options.");
}
/*
* Prepare processing: open temporary file.
*/
reverse_start(effp)
eff_t effp;
{
reverse_t reverse = (reverse_t) effp->priv;
reverse->fp = tmpfile();
if (reverse->fp == NULL)
fail("Reverse effect can't create temporary file\n");
reverse->phase = WRITING;
}
/*
* Effect flow: a degenerate case: write input samples on temporary file,
* don't generate any output samples.
*/
reverse_flow(effp, ibuf, obuf, isamp, osamp)
eff_t effp;
long *ibuf, *obuf;
int *isamp, *osamp;
{
reverse_t reverse = (reverse_t) effp->priv;
if (reverse->phase != WRITING)
fail("Internal error: reverse_flow called in wrong phase");
if (fwrite((char *)ibuf, sizeof(long), *isamp, reverse->fp)
!= *isamp)
fail("Reverse effect write error on temporary file\n");
*osamp = 0;
}
/*
* Effect drain: generate the actual samples in reverse order.
*/
reverse_drain(effp, obuf, osamp)
eff_t effp;
long *obuf;
int *osamp;
{
reverse_t reverse = (reverse_t) effp->priv;
int len, nbytes;
register int i, j;
register long temp;
if (reverse->phase == WRITING) {
fflush(reverse->fp);
fseek(reverse->fp, 0L, SEEK_END);
reverse->pos = ftell(reverse->fp);
if (reverse->pos % sizeof(long) != 0)
fail("Reverse effect finds odd temporary file\n");
reverse->phase = READING;
}
len = *osamp;
nbytes = len * sizeof(long);
if (reverse->pos < nbytes) {
nbytes = reverse->pos;
len = nbytes / sizeof(long);
}
reverse->pos -= nbytes;
fseek(reverse->fp, reverse->pos, SEEK_SET);
if (fread((char *)obuf, sizeof(long), len, reverse->fp) != len)
fail("Reverse effect read error from temporary file\n");
for (i = 0, j = len-1; i < j; i++, j--) {
temp = obuf[i];
obuf[i] = obuf[j];
obuf[j] = temp;
}
*osamp = len;
}
/*
* Close and unlink the temporary file.
*/
reverse_stop(effp)
eff_t effp;
{
reverse_t reverse = (reverse_t) effp->priv;
fclose(reverse->fp);
}